草庐IT

MySQL 查询返回重复结果

全部标签

ruby-on-rails - 让 find_by in rails 返回多个结果

我正在尝试返回用户创建的所有组。所有组都与用户标识相关联。当我运行find_by查询时,它只返回第一个结果。有没有办法让它返回多个?提前致谢 最佳答案 我正在写一个单独的答案,因为我没有50分,无法评论JamesLowrey的答案。find_all_by已弃用(Ruby4.2)。要从模型中获取事件记录列表,请执行以下操作:Model.where(attribute_name:val)例如,要在Vehicle表(具有列名称“model_name”)中查找所有记录,使得model_name的值为“Audi”,执行@vehicles=Ve

ruby-on-rails - rspec 在失败测试中的未决结果

it'shouldbeanarrayandnotbeempty'dopendingexpect(a.class).tobe(Array)expect(a.empty?).tobe(false)expect(a.first.class).tobe(ExampleClass)end当我运行rspec时:Failures:1)shouldbeanarrayandnotbeemptyFIXEDExpectedpending'Noreasongiven'tofail.NoErrorwasraised.#./spec/example_spec.rb:19知道为什么这会被列为失败吗?

ruby - 遍历数组并返回下一个和当前之前的元素

这个问题在这里已经有了答案:Rubyarrayaccess2consecutive(chained)elementsatatime(4个答案)关闭3年前。我如何在用每个元素迭代数组时从数组中获取下一个和之前的当前元素。array.eachdo|a|#Iwanttofetchnextandbeforecurrentelement.end

ruby-on-rails - 两次之间的 Rails 查询

我有一个Rails应用程序,它有一个Checkin模型。我想查找当天特定时间范围内的所有记录。我将如何编写where来获取在中午12点到下午4:30之间创建的所有记录? 最佳答案 @x1a4的答案应该对你有好处,但你可以使用范围以更易读和更短的方式来完成。Checkin.where(created_at:Time.parse("12pm")..Time.parse("4:30pm"))它应该生成如下内容:SELECT"checkins".*FROM"checkins"WHERE("checkins"."created_at"BETW

ruby - 在 Ruby + TinyTDS 中参数化 SQL 查询

我试图弄清楚如何在将SQL字符串交给执行之前对其进行参数化,但遗憾的是我发现了很多ofthis在互联网上:sql="SELECT*FROMtable_nameWHEREthingLIKE'%#{input}%'"这是一件坏事...但是,参数化sql查询在底层可用Sequel库,这是TinyTDS构建的基础。所以我知道这是可能的。我只是很难弄明白。我真的希望它能像this一样简单:@client=TinyTds::Client.new(:adapter=>'sqlserver',:host=>host,:database=>db,:username=>username,:password

ruby - 如何从 Ruby 中的 Mocha 模拟返回动态值

我的问题的要点如下:-我正在用Ruby为下面表示为“post_to_embassy”的方法编写一个Mocha模拟。出于描述问题的目的,实际方法的作用并不是我们真正关心的。但我需要模拟返回一个动态值。下面的proc'&prc'代替实际方法正确执行。但是Mocha中的“with”方法只允许返回bool值。所以下面的代码输出nil。我需要它来输出通过orderInfoXml传递的值。有人知道我可以使用的替代方法吗?require'rubygems'require'mocha'includeMocha::APIclassEmbassyInterfacedefpost_to_embassy(xm

sql - rails union hack,如何将两个不同的查询放在一起

我有一个查询,它在同一个表中搜索两个单独的字段...寻找最有可能是特定城市但也可能是国家的位置...即需要两个字段。表格看起来像:CountryCityGermanyAachenUSAAmarilloUSAAustin结果:KeywordSideinfoAachenGermanyUSACountryAustinUSAGermanyCountry基本上我想知道是否有更简洁的方法来执行此操作,因为我必须使用两个单独的查询,然后将它们加在一起,对它们进行排序等(效果很好):defself.ajax(search)countries=Location.find(:all,:select=>'c

ruby-on-rails - 当响应不断以 JSON 格式返回时,如何重定向到页面?

我正在使用dropzone.js用于图片上传。在我的coffeescriptjs文件中,我有dropzone的设置:Dropzone.autoDiscover=falsedropzone=newDropzone('#item-form',maxFiles:1maxFilesize:1paramName:'item[image]'headers:"X-CSRF-Token":$('meta[name="csrf-token"]').attr('content')addRemoveLinks:trueclickable:'#image-preview'previewsContainer:'

ruby - 从 Ruby 数组中删除顺序重复项

假设我有以下数组,我想去掉连续的重复项:arr=[1,1,1,4,4,4,3,3,3,3,5,5,5,1,1,1]我想得到以下信息:=>[1,4,3,5,1]如果有比我的解决方案(或其变体)更简单、更高效的东西,那就太好了:(arr+[nil]).each_cons(2).collect{|i|i[0]!=i[1]?i[0]:nil}.compact或(arr+[nil]).each_cons(2).each_with_object([]){|i,memo|memo编辑:看起来@ArupRakshit下面的解决方案非常简单。我仍在寻找比我的解决方案更高效的方法。编辑:我将在响应出现时对

ruby - 'array.each do |block|'在生成的 Haml HTML 中包含语句的结果

我正在生成一封电子邮件,其中包含来自Haml模板的动态内容,该模板解析数组中的信息。基本上,Haml接收一个包含多个哈希值的数组。在代码中,我有一个如下所示的block:%table=arrayname.eachdo|object|%tr%td=object.name%td=object.link每当发送电子邮件时,整个对象arrayname都包含在HTML的底部。这会导致[#,#](当有更多对象时更多#)显示在block的顶部。没有办法用CSS操纵这段文本,否则我会把它隐藏起来。[#,#]该行与在IRB中执行代码时显示的结果相同。谁能告诉我如何防止这种情况发生?